.book-ol-rank {
    counter-reset:bookrank;
}
.book-toplist {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 7.5rem;
}
.book-toplist-cover {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.book-toplist-title {
    font: normal 1.75rem/1.375rem KUHEI;
    position: absolute;
    right: 0;
    bottom: 6rem;
    left: 0;
    -webkit-transform: scaleY(1.2);
    transform: scaleY(1.2);
    text-align: center;
    color: #fff;
}
.book-toplist .icon-point-r {
    position: absolute;
    right: 0;
    bottom: 2rem;
    left: 0;
    width: 1.5rem;
    height: 1.5rem;
    margin: auto;
    color: #fff;
    background: url(../images/download.svg) no-repeat center/100% 100%;
}
.book-toplist+.book-ol {
    overflow: hidden;
    margin-left: 7.5rem;
    padding-left: 2.125rem;
}
li {
    display: list-item;
    text-align: -webkit-match-parent;
}
.book-ol-rank .book-li {
    position: relative;
    counter-increment:testname;
}
.book-toplist+.book-ol .book-li {
    box-shadow: 0 1px #f0f1f2;
}
.book-ol-rank .book-li::before {
    font: bold 1em/1.5em 'DIN Alternate';
    position: absolute;
    top: 0;
    bottom: 0;
    left: -2.125rem;
    height: 1.5em;
    margin: auto;
    content: counter(bookrank) '.';
    counter-increment: bookrank;
}
.book-toplist+.book-ol .book-li::before {
    left: -1.125rem;
}
.book-layout {
    position: relative;
    display: block;
    overflow: hidden;
    padding: 1rem;
    -webkit-transition: padding-left .15s;
    transition: padding-left .15s;
}
.book-toplist+.book-ol .book-layout {
    font-size: .875rem;
    line-height: 1.5rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    margin-left: -2.125rem;
    padding: .375rem 1rem .375rem 2.375rem;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}
.book-title {
    line-height: inherit;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    font-size: 15px;
}
.book-toplist+.book-ol .book-layout {
    font-size: .875rem;
    line-height: 1.5rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    margin-left: -2.125rem;
    padding: .375rem 1rem .375rem 2.375rem;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}
.book-author {
    font-size: .8125rem;
    display: block;
    overflow: hidden;
    max-width: 10em;
    max-width: calc(100vw - 2rem - (176rem / 16));
    white-space: nowrap;
    text-overflow: ellipsis;
    color: #969ba3;
}
.book-toplist+.book-ol .book-author {
    overflow: visible;
    margin-left: 5px;
}
.book-li::after {
    border-bottom: 0;
}